layui.use(['table', 'HttpRequest', 'func'], function () {

    var $ = layui.$;
    var table = layui.table;
    var HttpRequest = layui.HttpRequest;
    var func = layui.func;

    /**
     * 用户好友联系人表管理
     */
    var UserContacts = {
        tableId: "userContactsTable"
    };

    /**
     * 初始化表格的列
     */
    UserContacts.initColumn = function () {
        return [[
            {type: 'checkbox'},
            {field: 'id', hide: true, title: '主键Id'},
            {field: 'name', sort: true, title: '真实姓名'},
            {field: 'namePinyin', sort: true, title: '真实姓名的中文拼音'},
            {field: 'sex', sort: true, title: '性别'},
            {field: 'phone', sort: true, title: '电话号码'},
            {field: 'qq', sort: true, title: 'qq号'},
            {field: 'wechatNumber', sort: true, title: '微信号'},
            {field: 'email', sort: true, title: '电子邮件'},
            {field: 'calendarMode', sort: true, title: '日历方式'},
            {field: 'birthDay', sort: true, title: '用户生日'},
            {field: 'remarks', sort: true, title: '备注'},
            {align: 'center', toolbar: '#tableBar', title: '操作'}
        ]];
    };

    /**
     * 点击查询按钮
     */
    UserContacts.search = function () {
        var queryData = {};
        queryData['condition'] = $("#condition").val();
        table.reload(UserContacts.tableId, {
            where: queryData, page: {curr: 1}
        });
    };

    /**
     * 弹出添加对话框
     */
    UserContacts.openAddDlg = function () {
        func.open({
            title: '添加用户好友联系人表',
            content: Feng.ctxPath + '/view/shop/userContacts/add',
            tableId: UserContacts.tableId
        });
    };

    /**
    * 点击编辑
    *
    * @param data 点击按钮时候的行数据
    */
    UserContacts.openEditDlg = function (data) {
        func.open({
            title: '修改用户好友联系人表',
            content: Feng.ctxPath + '/view/shop/userContacts/edit?id=' + data.id,
            tableId: UserContacts.tableId
        });
    };

    /**
     * 导出excel按钮
     */
    UserContacts.exportExcel = function () {
        var checkRows = table.checkStatus(UserContacts.tableId);
        if (checkRows.data.length === 0) {
            Feng.error("请选择要导出的数据");
        } else {
            table.exportFile(tableResult.config.id, checkRows.data, 'xls');
        }
    };

    /**
     * 点击删除
     *
     * @param data 点击按钮时候的行数据
     */
    UserContacts.onDeleteItem = function (data) {
        var operation = function () {
            var request = new HttpRequest(Feng.ctxPath + "/shop/userContacts/delete", function (data) {
                Feng.success("删除成功!");
                table.reload(UserContacts.tableId);
            }, function (data) {
                Feng.error("删除失败!" + data.responseJSON.message + "!");
            });
            request.set("id", data.id);
            request.start();
        };
        Feng.confirm("是否删除?", operation);
    };

    // 渲染表格
    var tableResult = table.render({
        elem: '#' + UserContacts.tableId,
        url: Feng.ctxPath + '/shop/userContacts/findPage',
        page: true,
        cellMinWidth: 100,
        cols: UserContacts.initColumn(),
        request: {pageName: 'pageNo', limitName: 'pageSize'},
        parseData: Feng.parseData,
        done: function(){
            $("[data-field = 'sex']").children().each(function(){
                if($(this).text() == '1'){
                    $(this).text("男");
                }else if($(this).text() == '0'){
                    $(this).text("女");
                }
            });

            $("[data-field = 'calendarMode']").children().each(function(){
                if($(this).text() == '0'){
                    $(this).text("阳历");
                }else if($(this).text() == '1'){
                    $(this).text("农历");
                }
            });
        }
    });

    // 搜索按钮点击事件
    $('#btnSearch').click(function () {
        UserContacts.search();
    });

    // 添加按钮点击事件
    $('#btnAdd').click(function () {
        UserContacts.openAddDlg();
    });

    // 导出excel
    $('#btnExp').click(function () {
        UserContacts.exportExcel();
    });

    // 工具条点击事件
    table.on('tool(' + UserContacts.tableId + ')', function (obj) {
        var data = obj.data;
        var layEvent = obj.event;

        if (layEvent === 'edit') {
            UserContacts.openEditDlg(data);
        } else if (layEvent === 'delete') {
            UserContacts.onDeleteItem(data);
        }
    });
});
